<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>事件处理</title>
    </head>
    <body>
        <!-- 准备好一个“容器” -->
        <div id="test"></div>

        <!-- 引入react核心库 -->
        <script src="../js/react.development.js" type="text/javascript"></script>
        <!-- 引入react-dom，用于支持react操作DOM -->
        <script src="../js/react-dom.development.js" type="text/javascript"></script>
        <!-- 引入babel，用于将jsx转为js -->
        <script src="../js/babel.min.js" type="text/javascript"></script>

        <script type="text/babel">
            //创建组件
            class Demo extends React.Component {
                /*
                    (1).通过onXxx属性指定事件处理函数(注意大小写)
                            a.React使用的是自定义(合成)事件, 而不是使用的原生DOM事件 —————— 为了更好的兼容性
                            b.React中的事件是通过事件委托方式处理的(委托给组件最外层的元素) ————————为了的高效
                    (2).通过event.target得到发生事件的DOM元素对象 ——————————不要过度使用ref
                 */
                //创建ref容器
                myRef = React.createRef()
                myRef2 = React.createRef()

                //展示左侧输入框的数据
                showData = (event) => {
                    console.log(event.target);
                    alert(this.myRef.current.value);
                    alert(this.myRef.current.type);
                }

                //展示右侧输入框的数据
                showData2 = (event) => {
                    alert(event.target.value);
                }

                render() {
                    return (
                        <div>
                            <input ref={this.myRef} type="text" placeholder="点击按钮提示数据"/>&nbsp;
                            <button onClick={this.showData}>点我提示左侧的数据</button>
                            &nbsp;
                            <input onBlur={this.showData2} type="text" placeholder="失去焦点提示数据"/>&nbsp;
                        </div>
                    )
                }
            }

            //渲染组件到页面
            ReactDOM.render(<Demo a="1" b="2"/>, document.getElementById('test'))
        </script>
    </body>
</html>